package cn.cl.gulimall.ware.service.impl;

import org.springframework.stereotype.Service;

import java.util.List;
import java.util.Map;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import cn.cl.common.utils.PageUtils;
import cn.cl.common.utils.Query;

import cn.cl.gulimall.ware.dao.PurchaseDetailDao;
import cn.cl.gulimall.ware.entity.PurchaseDetailEntity;
import cn.cl.gulimall.ware.service.PurchaseDetailService;
import org.springframework.util.StringUtils;


@Service("purchaseDetailService")
public class PurchaseDetailServiceImpl extends ServiceImpl<PurchaseDetailDao, PurchaseDetailEntity> implements PurchaseDetailService {

	@Override
	public PageUtils queryPage(Map<String, Object> params) {
		QueryWrapper<PurchaseDetailEntity> queryWrapper = new QueryWrapper<>();
		String key = (String) params.get("key");
		if (!StringUtils.isEmpty(key)) {
			queryWrapper.and((w) -> {
				w.eq("purchase_id", key)
						.or()
						.eq("sku_id", key);
			});
		}
		String status = (String) params.get("status");
		if (!StringUtils.isEmpty(status)) {
			queryWrapper.eq("status", status);
		}
		String wareId = (String) params.get("wareId");
		if (!StringUtils.isEmpty(wareId)) {
			queryWrapper.eq("ware_id", wareId);
		}
		IPage<PurchaseDetailEntity> page = this.page(
				new Query<PurchaseDetailEntity>().getPage(params),
				queryWrapper
		);
		return new PageUtils(page);
	}

	@Override
	public List<PurchaseDetailEntity> listDateilByPurchaseId(Long id) {
		List<PurchaseDetailEntity> purchaseDetailEntities = this.list(new QueryWrapper<PurchaseDetailEntity>().eq("purchase_id", id));
		return purchaseDetailEntities;
	}

}